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(54) Reminder system for broadcast and non-broadcast events 



(57) A system and method provide a generalized 
reminder system in an interactive broadcast environ- 
ment, that enables a viewer to quicWy establish remind- 
ers for both broadcast events and non-broadcast 
events, and have such reminders displayed at an appro- 
priate future time. The system includes a broadcast that 
broadcasts programs, such as television pro-ams and 
commercial advertisements, and interactive applica* 
tlons associated with various such programs. The inter- 
active applications include reminder Interactive 
applications which have reminder data which describe a 
future time for dsplaying a reminder and a description 
of the event for which the reminder is desired. The 
broadcast programs and reminder interactive applica- 
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tions are received in broadcast receiver which displays 
the programs. A viewer viewing a program signals the 
broadcast receiver to establish a reminder for an event 
related to the program. The broadcast receiver stores 
the reminder data from the reminder interactive applica- 
tion, and initiates a timer that expires at the desired 
future time. When the timer expires, the broadcast 
receiver displays the event description tor the reminder. 
Reminders may be established and displayed for both 
broadcast events and non-broadcasts events, as the 
description of the event is contained in the reminder 
data. 
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Description 

CROSS REFERENCE TO RELATED APPUCATIONS 

[0001 ] The subject matter of this application is related 
to the subject matter of U.S. Pat Na 5.689.799. entitled 
"METHOD AND APPARATUS FOR ROUTING CONFI- 
DENTIAL INFORMATION", which issued on November 
18. 1997 and the foliowing applications: application 
serial number 08/429,064, entitled "METHOD AND 
APPARATUS FOR DETERMINING BROADCASTER 
INFORMATION^ filed on April 26, 1995. and application 
serial nurrtjer 08/429.107. entitled "COMPACT 
GRAPHICAL INTERACTIVE INFORMATION SYS- 
TEM", filed on April 26. 1995. The above patent and 
applications have the same assignee as ttie present 
invention and are incorporated herein by reference in 
their entirety. 

BACKGROUND 

Field of Invention 

[0002] The present invention relates generally to inter- 
active broadcast systems, and more partculariy to 
apparatuses and methods for establishing and oonmnu- 
nicating reminders to a viewer about broadcast and 
non-broadcast events. 

Background of the Invention 

[0003] Interactive broadcast systems, such as interac- 
tive television, provide the viewer with an enhanced 
viewing experience, typically allowing the viewer to 
engage with interactivity associated with individual tele- 
visions programs or advertising content. The interactiv- 
ity is typically provided to the viewer's broadcast 
receiver (e.g. television receiver, or set top box) by 
broadcast from a central host, such as a cable head- 
end. Viewer responses are communicated back from 
the broadcast receiver to the cable head-end by a back 
channel communication linK such as telephone con- 
nection. In this fashion the cable head-end can broad- 
cast content particular to a viewer's responses. 
However, in this approach all interactivity is controlled 
and produced at the cable head-end. the broadcast 
receiver is generally used merely for display of the inter- 
activity and receipt of viewer inputs. 
[0004] With the vast array of broadcast offerings, view- 
ers may like to have a nneans for reminding them in the 
future to watch a particular broadcast event, such as a 
television show or movie. It is desirable that a viewer 
can easily, and on impulse, establish such a reminder, 
without cunribersome or mode-based programming. In 
addition, advertisements often broadcast information 
about non-broadcast events, such as upcoming sales at 
department stores, limited time offers to purchase items 
on a shopping channel, and limited time offers to sub- 



scribe to premium channel services being offered on a 
channel other than the one being watched by the 
viewer. 

[0005] Some interactive cable systems provide limited 

5 means for establishing reminders. For example, Lawler, 
etal.. U.S. Patent No. 5.699.107 discloses an on-screen 
program selection guide that displays information about 
future broadcast programs, and with which tiie viewer 
can program reminder data to view a certain future 

10 broadcast at a certain time. This reminder data is trans- 
mitted from the broadcast receiver to tiie cable head- 
end where it is stored and monitored. At the designated 
time, the cable head-end transmits a message to the 
viewer's broadcast receiver with the reminder to view 

IS the broadcast. However, t>ecause this system is based 
on selection of broadcast items from a program selec- 
tion guide, it cannot be used to establish reminders for 
non-broadcast related events. Further, this niethod 
requires the viewer to actuate tiie program guide, review 

so it for a desired program, and set tiie renrvnder. Because 
the viewer must use the program guide in tilts manner 
lor any reminder, this approach thus does not allow the 
viewer to immediately establish a reminder at any time 
based on the broadcast program she is currentiy view- 

25 ing, without having to activate a separate programming 
guide. For exanple, if the viewer sees an advertisement 
for a television program that is to be broadcast the fol- 
lowing week, she must activate tiie program guide, 
search through It tor the listing of the desired program in 

30 the desired time slot next week, and select this program 
to establish tiie reminder data. This process interferes 
with the viewer's viewing of what was being broadcast. 
Indeed, if tiie adverstisement ^s before the viewer is 
done programnriing the reminder data, she may miss a 

35 portion of a television program that she was watching. 
Finally, this type of system stores tiie reminder data at 
the cable head-end, and makes tiie cable head-end 
responsible for managing tiie reminder data of hun- 
dreds, perhaps thousands of viewers. This approach is 

40 highly inefficient but results from the inability of conven- 
tional broadcast receivers to store and actively monitor 
reminder data. 

SUMMARY OF THE INVENTION 

45 

[0006] The present invention overcomes the limita- 
tions of conventional systems by providing a general- 
ized system and method that allows fa tiie 
establishment and communication of reminders tor both 

50 broadcast and non-broadcast events. The present 
invention further enables the viewer to immediately 
establish a reminder based on a cun'entiy viewed broad- 
cast item, witiiout having to tiBverse through complex 
program guides. Further, the viewer can estat)lish 

55 reminders ttiat relate to either future broadcast events, 
or to future non-broadcast events. For example, with the 
present invention, when viewing an advertisement tor a 
sale at a department store tinat begins in three days, the 
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viewer can set a reminder for that sale; the reminder 
that the sale has started is displayed to the viewer when 
the viewer uses their television in three days' time. The 
reminder data is preferably stored locally at the viewer's 
broadcast receiver, thereby eliminating the burden on 5 
the broadcaster or cable head-end to manage remind- 
ers for potentially tens of thousands of viewers. 
[0007] A system in accoftiance with the present inven- 
tion includes a broadcast system that broadcasts inter- 
active applications in association with broadcast to 
programs, including television programs and comnr>er- 
cial advertisements. The interactive applications include 
reminder Interactive applications tor establishing 
reminders about broadcast events, such as upcoming 
television programs, and non-broadcast events, such as is 
a retail sales event, related to broadcast program, such 
as a commercial advertisement for the retail sales 
event The system Includes a broadcast receiver that 
receives the broadcast programs and the associated 
interactive applications, displays the broadcast pro- 20 
grams, and executes the associated renrinder interac- 
tive application. When a viewer is viewing a broadcast 
program, she may instruct the broadcast receiver to 
establish reminder data related to tiie broadcast event 
or a non-broadcast event associated with the broadcast 25 
event. Execution of the reminder application receives 
the reminder data and stores it in the memory, and initi- 
ates a timer based upon the reminder data to count- 
down the time remaining for the reminder data. The 
broadcast receiver may store multiple different timers so 
for different reminders. The reminder data is preferably 
defined within with the reminder interactive application, 
so that the user has to program as littie data as possible. 
For example, the reminder interactive application may 
include the date, time, and description of the event for 35 
which tiie reminder is desired. In tfiis fashion the user 
need only to activate the reminder interactive applica- 
tion when viewing the broadcast program, and need not 
select a specific program in a complex program guide to 
set tie reminder data. ^ 
[0008] During subsequent' viewing, when a timer 
expires, the broadcast receiver displays a reminder dis- 
play on a display such as the viewer's television, provid- 
ing descriptive information of the reminder, such as the 
date, time, and description of tiie broadcast or non- 4S 
broadcast event. 

[0009] A metiiod in accordance with the present 
invention includes receiving broadcast data including at 
least one broadcast pro^^am and a reminder interactive 
application associated with the broadcast program, so 
receiving a user input to establish a reminder for an 
event associated with the broadcast program, executing 
the reminder interactive application to establish 
reminder data for the event in a broadcast receiver 
establishing in the broadcast receiver a timer based 55 
upon the reminder data, and providing a display of the 
reminder from the reminder data upon expiration of the 
timer. 



BRIEF DESCRIPTION OF THE DRAWINGS 
[0010] 

Rg. 1 is an illustration of a system in accordance 
witii the present invention. 
Rg. 2 is an illustration of the tyoadcast receiver. 
Rg. 3 is a flowchart of a method for executing an 
interactive application. 

Rg. 4 is a flowchart of a method in accordance with 
the present invention. 

Rg. 5 is an illustration of a user interface for estab- 
lishing a reminder for an event. 
Rg. 6 an Illustration of a reminder display for a 
broadcast o/ent 

Rg. 7 is an Illustration of a remirxier confirmation 
display for a non-broadcast event. 

DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENT 

[001 1 ] Referring now to Rg. 1 , there is shown an illus- 
tration of a system in accordcmce with the present 
invention. It will be appreciated that the system Illus- 
trated in Fig. 1 may be incorporated in to larger, more 
complex systems while still providing tiie features and 
benefits of tiie invention. Generally, system 100 
includes a broadcaster 114, a broadcast server 110, a 
data insertion unit 116, and at least one broadcast 
receiver fBRT120. 

BR O AD CASTE R 

[001 2] The broadcaster 114 provides program mate- 
rial to be broadcast to the BRs 120. As used herein, a 
"broadcaster" 114 is any entity providing a program tiiat 
will be can-ied on a broadcast signal. A "program" is a 
discrete segment of a broadcast. Thus, as defined 
herein, programs include television shows, commer- 
cials, public service announcements, pay-per-view 
events, and the like. Broadcasters include television 
networks, as well as advertisers who prepare commer- 
cials, pay-per-view provkJes. cable networks, and tiie 
like. A typical broadcaster 114 maintains program 
sources, such as banks of vkieo cassette players, video 
disc players, film, and the like containing program mate- 
rial; automation systems that selectively control the pro- 
grams sources to select which units provide program 
material at which times; and switching systems conti"Ol- 
ted by the automation systems which couple the pro- 
gram sources to respective broadcast media for 
controlling which program sources output to which 
broadcast mediums at any given time. The person or 
persons receiving the programs are referred to as "sii> 
scrit^ers" or 'Viewers. 

[0013] Generally, a broadcaster 114 will broadcast 
programs associated with broadcast events, or non- 
broadcast events. Programs associated with broadcast 
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events include advertisements for future television pro- 
grams, movies, pay-per-view events, specials, and the 
like, and programs that are viewed in and of themselves. 
For example, an episode of a weekly television program 
is associated by its weekly nature with the folk)wing 5 
week's episode. Programs associated with non-broad- 
cast events include advertisements for events such as 
retail events, concerts, meetings, conventions, pro- 
grams that notify the viewer in advance of the non- 
broadcast event, and the like. For example, an adver- w 
tisement for a department store sale would be a pro- 
gram associated with a non-broadcast event. 

BROADCAST SERVER 

IS 

1001 4] The broadcast sen/er 1 1 0 is preferably a com- 
puter system executing a software program providing 
the functionality desaibed herein. The broadcast sender 
110 contains an interactive application database 112. 
The interactive application database 112 stores interac- 20 
tive applications that will be broadcast to various 
renxrtely distributed BRs 120. Interactive applications 
may be added to the interactive applications database 
1 1 2 by a broadcaster 1 14 or other program supplier and 
may be transmitted to the database 112 by a secure 25 
network link or other transmission media. ReWs within 
the database 112 associate interactive applications 
with, for example, a particular broadcaster, network, 
channel, program, and/or broadcast time. In addition, 
each interactive application in the database 112 prefer- so 
ably has a unique interactive application identificatfon 
code by which it may be identified. 
[0015] In one embodiment of the present invention, 
the interactive applications stored in the database 112 
are desaibed by a conpact communications protocol. 35 
The compact protocol is designed to broadcast a com- 
pact set of information and commands among the sys- 
tem components in an efficient manner, thereby 
allowing the use of low bandwidth transports such as 
the vertical blanking interval CVBI"). While a preferred 40 
embodiment of the present inventfon uses the compact 
protocol described herein, interactive applicatfons may 
be described by other protocols, including for example, 
the Hypertext Markup Language ("HT^n or SUN 
MICROSYSTEMS INC/s JAVA language. A detailed 45 
deso-iption of one conpact protocol suitable for interac- 
tive applications, including stpported definitions, 
scripts, and commands, is described in U.S. Pat No. 
5,689,799, entitled "Method and Apparatus for Routing 
Confkiential Infamation/ which issued on November so 
18. 1995 and is hereby incorporated by reference 
herein. The interactive applications are themselves soft- 
ware products comprising executable code and data, 
which configures and controls the operation of a broad- 
cast receiver 120, as further descrik>ed below. ss 
[001 6] In one embodiment, the inrteractive applications 
database 112 includes reminder interactive applications 
which set and establish reminders for broadcast and 



non-broadcast events. In a preferred embodiment, a 
reminder interactive application includes forms to con- 
firm or cancel a reminder for a event forms to display a 
reminder for an everrt, scripts to (fisplay and manage the 
fomis, and data deff ^ling the details of a reminder to be 
provided to the viewer. The event description contains 
information useful to both the broadcast receiver 120 to 
configure itself to establish and manage the reminder if 
so requested by the viewer, and information useful to 
the viewer to describe the event for which the reminder 
is established. In a preferred errtxxJiment. the event 
description includes; 

Event name: data providing a name or other identi- 
fying infomnation for the viewer to recognize the 
event. TTie event name may also indude unique 
kJentifying data used only by the broadcast receiver 
120 to identify the event desaiption. 

• Event dateAime: data defining a date and/or time for 
a reminder to be displayed. 

• Event channel: for broadcast events, data defining 
the network and/or channel on which the broadcast 
event will occur. This data is useful to allow the 
broadcast receiver 120 to automatically tune to the 
specified channel so that tiie viewer may immedi- 
ately view the broadcast event. 

• Reminder data: data defining the time{s) when a 
reminder is to be displayed to the viewer. 

(001 7] There may be a plurality of broadcast senders 
110, witii each broadcast server 110 sennng a particu- 
lar geographic area, set of broadcasters, or set of sub- 
scribers. In one embodiment, each broadcast server 
110 is identified by a unk^ue server identification code. 
[0018] Generally, the broadcast server 110 deter- 
mines which interactive applications should be broad- 
cast on a particular channel at a particular time, 
retrieves the interactive applications con-esponding to 
tiie particular channel arKt time from tiie database 112, 
and prepares the interactive applications for broadcast. 
[001 9] To determine which interactive applications are 
broadcast at the varfous times, channels, and so forth, 
the broadcast server 110 receives a playlist 113 of pro- 
grams to be broadcast by the broadcaster 114. In one 
embodiment this playlist 113 is prepared in advance 
and identifies tiie progranrrs that will be broadcast by the 
broadcaster 114 at particular times. In another embodi- 
ment, the broadcast server 110 receives the playlist 113 
in real-time, identifying tiie program currently being 
broadcast by tiie broadcaster 114. with the playlist 113 
being updated as the broadcast changes. In either 
embodiment the playlist 113 contains sufficient infor- 
mation to identify each program, its start and end times, 
the channel and network assignments, or broadcaster 
identification code. The broadcast server 110 uses ttiis 
inforniation to identify and retrieve a corresponding 
interactive application from tiie datatrase 112 that is to 
accompany the program. 
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[0020] For example, a broadcaster 114 may broadcast 
advertisement for a future broadcast event such as a 
special movie presentation. The broadcaster 114 may 
define a reminder interactive application that is to be 
broadcast with the advertisement. This reminder inter- s 
active application will be stored in the interactive appli- 
cation database 112 with information identifying the 
advertisement, and if necessary, the broadcaster identi- 
fication code and broadcast times. When the broadcast 
sen/er 1 1 0 receives a playlist 113 containing identifying w 
information for the advertisement it retrieves the 
reminder interactive application, for example by match- 
ing the broadcaster identification code, channel assign- 
ment for the advertisement, and broadcast times with 
con-esponding information in the interactive application 75 
database 112. 

[0021 ] The broadcast server 110 formats a reti'ieved 
interactive application, if necessary, and othenwise pre- 
pares it for insertion into a broadcast signal. Using the 
playlist 113 received from the broadcaster 114, the so 
broadcast server 110 passes the interactive application 

115 to tine data insertion unit TDIU") 116 to incorporate 
the interactive application 115 into the broadcast data 
1 1 7 concurrent with the broadcast of the program. 

25 

DATA INSERTION UNIT 

[0022] The DIU 116 receives tine interactive applica- 
tion 115 from the broadcast server 110 arxJ tiie broad- 
cast signal, or feed, candying the program conesponding so 
to the interactive application 115. The broadcast feed 
may be received from ttie broadcaster 114, or. in the 
case where the broadcaster does not provide the feed, 
from a third party such as a networK cable operator, or 
local television station. The DIU 1 16 converts the inter- 35 
active application 115 into a format 8uitat>le for insertion 
into the broadcaster feed and tiansmission therewitii as 
broadcast data 117, The DIU 116 may receive feeds 
from multiple broadcasters and can insert a s^>arate 
interactive application into each feed. Likewise, the DIU 40 

116 can simultaneously insert a separate interactive 
application into multiple channels from the same, or dif- 
ferent, broadcasters 114. 

[0023] The DIU 1 1 6 inserts the broadcast data 1 1 7 
containing the interactive applications and broadcast 45 
programs into the broadcast medium. The broadcast 
medium is the frequency spectrum used to carry the 
interactive application 115. In one embodiment the 
broadcast medium is a standard analog television sig- 
nal following National Television Standards Committee so 
("NTSC") standards and tiie VBI is used as a transport 
to broadcast the interactive application. The transport is 
the specific portion of tiie broadcast medium which car- 
ries tiie interactive application 115. In another embodi- 
ment, tiie broadcast medium is a standard MPEQ2 ss 
Digital Video Multiplex, containing one or more MPEG2 
Video Services, and a MPEQ2 elementary stream (or 
sfeams) witiiir tiiis multiplex is used as a transport 



[0024] In one embodiment the D I U 1 1 6 uses conven- 
tional mettiods to insert data defining an interactive 
application into the VBI of the broadcast feed. The 
Nortii American Broadcast Teletaxt Standard (EIA-506), 
defines the methods and protocols for sending data in 
one or more lines of the VBI. However, a wide variety of 
otfier tiansport mechanisms are available, including 
ttiose tiiat broadcast the interactive application 1 1 5 sep- 
arately from tiie television program. Such ti-ansport 
mechanisms include out-of-band transmitters, which 
transmit the interactive application 115 on an unused 
portion of the telo^sion frequency spectrum, and con- 
ventional frequency nxxlulation ("FM") radio transmit- 
ters, which transntit tiie interactive application 115 
outside the television frequency spectrum. In another 
embodiment the DtU uses conventional methods to 
insert data into an elementary stream wittiin a MPEG2 
multiplex. 

[0025] In one embodiment en-or checking or en-or cor- 
recting codes such as Hamming codes are inserted with 
tiie data. InoneembocSment tiie DIU 116 translates tiie 
data into a Hamming code, and in another embodiment, 
the data received by the DIU 116 from the broadcast 
server 110 is already encoded. 

TRANSMITTER 

[0026] The DIU 1 16 is coupled to a transmitter 1 18 for 
transmitting tiie broadcast feed. Including the inserted 
interactive application. In one errbodiment. tiie tirans- 
mitter 118 is a satellite uplink ti'ansmitting the feed to 
k)cal uplink receivers which then distritxrte tiie feed to 
the BRs 120 via cattle. In another embodiment, tiie 
tiansmitter 118 is a conventional cable system head- 
end amplifier, in yet other embodiments, tiie transmitter 
1 18 is a conventional television broadcast tiansmitter or 
a high-definition television digital transmitter. 
[0027] In another embodiment the DIU 116 inserts 
tiie interactive application 115 into ttie program before 
the program is broadcast. For example, ttie DIU 116 
may insert an interactive application into ttie source 
copy of a television commercial. Accordingly, the inter- 
active application is broadcast wtienever the commer- 
dal is broadcast. In ttiis embodiment, the broadcast 
serve'' 110 does not need to synchronize the refri wal of 
ttie interactive application witti ttie schedule listed in ttie 
playlist 

[0028] Regardless of transmission mettiod and inser- 
tion time, ttie broadcast data 117, including the interac- 
tive application, is received by a subscriber's BR 120. 
Although only a single BR 1 20 is illustrated in Fig. 1 . it is 
understood that in a typical embodiment there are hun- 
dreds or tiiousands of BRs 120 receiving ttie broadcast 
data 1 17 end responding as described herein. In partic- 
ular, each broadcast receiver 120 may individually set 
and establish reminders for broadcast and non-broad- 
cast events as desired by their respective users. In a 
typical embodiment, ttie BR 120 is a television set-top 
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box receiving the data 11 7 via a coaxial cable. Additon- 
ally, the BR 120 may be integrated into the television. 
Moreover, other broadcast receivers, including a NTSC 
broadcast receiver, a high-definition television c£gital 
receiver, a video cassette recorder, or a FM radio s 
receiver can also be used. 

BROADCAST RECEIVER 

[0029] Fig. 2 illustrates an embodiment of the BR 1 20 io 
according to an embodiment of the present invention. In 
one embodiment, the BR 120 is the General Instrument 
CFT-2200 CATV set-top decoder. The BR 120 includes 
a tuner 202 for receiving the broadcast data 117 from 
the transmitter 1 18. In one embodiment the tuner 202 is is 
a conventional cable television tuner. In other embodi- 
ments, the tuner is a television broadcast tuner, a FM 
radio tuner, a cfigital tuner, or some other fomi of tuner. 
The embodiment illustrated in Fig. 2 shoMS a display 
218. typically a television, within the BR 120. As men- 20 
tioned above, the display 218 may also be located exter- 
nal to the BR 120. 

[0030] The BR 120 also includes a data extractor 206 
coupled to the tuner 202 for extracting the interactive 
application from the broadcast data 1 1 7. In one embod- ss 
iment, the data extractor 206 is a conventional V6I 
inband data extraction drcurt In another embodimertt 
the data extractor 206 is a conventional modem. The 
data extractor 206 provides a serial bitstream contain- 
ing the extracted interactive application onto a bus 208. so 
The bus 208 is coupled to a microprocessor 210 which 
stores, via the bus 208, the extracted interactive appli- 
cation into a first storage device 212 as instructed by a 
program stored in a second storage device 214. In one 
embodiment, the microprocessor 210 uses the error ss 
code information from the extracted data to check or 
con^ect errors in the decoded interactive application. In 
one embodiment the first storage device 212 is a con- 
ventional random access memory ("RAM") while the 
second storage device 214 is a conventional read-only 4o 
memory ("ROM"). A third storage device 213. which 
may be RAM or flash memory, is coupled to the micro- 
processor 210 to store reminder data. An advantage of 
flash memory is that software a data resident in the BR 
120 can be modified by a received interactive applica- 4s 
tion. 

[0031 ] In one embodiment, the BR 120 also uses the 
data extractor 206 to extract a time signal from the 
broadcast data 117. The time signal indicates the cur- 
rent time using a standard timebase. such as Coordi- so 
nated Universal Time ("UTC") or the subscriber's local 
time. In another embodiment, the BR 120 has a real- 
time dock that is either set t>y the subscriber or the 
received time signal. Regardless, the BR 120 preferably 
has access to the current time and. accordingly, can ss 
perform date stamping and timing functions. 
[0032] As described below, the miaoprocessor 210 
uses the program stasd in the second storage device 



214 arKl the interactive application stored in the first 
storage device 21 2 to execute the interactve application 
and provide an output. The program stored in the sec- 
ond storage device 214 is preferably an execution 
engine 217 for executing an interactive application 
defined by various saipts, forms, definitions, and code 
and graphic resources. A preferred execution engine is 
the Wink Engine provided by Wink Comnrunications. 
Inc. of Alameda, Calrfomia. The broadcast receiver 120 
includes either as part of the execution engine 217. or 
the native operating system 219 also stored in the sec- 
ond storage device 214, timer functions that can be run 
as background processes to countdown from an input 
values or equivalent timing specification. 
[0033] The output from executing an interactive appli- 
cation may be. for example, a form presenting informa- 
tion or a menu to a television viewer or for receiving 
viewer input, or it may be a response, silent or other- 
wise, containing BR 1 20 or television usage data or indi- 
cating viewer prefererK:es. For purposes of the present 
invention, the form may be a form to set or cancel a 
rminder. or to remind the viewer of an upcoming broad- 
cast or non-broadcast event. To this end. the BR 120 
preferably includes a graphics overlay generator 216 
coupled to the bus 208 and driven by the interactive 
application 115 stored in the first storage device 212 
and the program stored in the second storage device 
214. The graphics overlay generator 216 generates a 
graphical display responsive to the interactive applica- 
tion 1 1 5. This graphical display is displayed on a display 
218. typically a televiston. coupled to the BR 120. Of 
course, the graphics overlay generator 216 is typkally 
not used when an interactive application silently exe- 
cutes. 

[0034] In one embodiment, the graphics overlay gen- 
erator 216 also receives the broadcast signal corre- 
sponding to a broadcast program from the tuner 202 to 
allow simultaneous display of the broadcast program 
and the graphical aspects, if any. of the interactive appli- 
cation 115. for example, to input data into a displayed 
form to set or cancel a reminder. In one embodiment, 
the miaoprocessor 210 is also coipled to a user input 
decoder 222 coupled to a user input receiver 224 to 
allow the user to communicate with the microprocessor 
210 in order to respond to the interactive application 
115. In one embodiment the user input decoder 222 is 
a conventional infrared renrxste control decoder. The 
user input receiver 224 is preferably a converrtional 
infrared receiver 224 with which the user may use a 
conventional hand-held remote control device. Renxjte 
control keys pressed by the user translate to coded 
infrared signals that are received by the user input 
receiver 224. are decoded by the user input decoder 
222, and sent to the microprocessor 210 to allow the 
user to communicate with the interactive application 
115. 

[0035] In one embodiment the BR 1 20 is a cable TV 
set-top decoder, connected to a cable system via a 
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broadband coax cable, in Itiis embodiment, line driver 
230 is an RF modem which is capable of sending 
responses via the coax cable to the cable system head- 
end, typically using an out-of-band portion of the RF 
spectrum, and communications port 232 is a standard 5 
RF tap. In another embodiment, the BR 120 is a televi- 
sion. VCR, or set-top in which line driver 230 is a stand- 
ard telephone modem and communications port 232 is 
a standard RJ-1 1 jack. 

[0036] The microprocessor 21 0 may also be coupled 10 
to a conventional infrared command encoder 226, which 
accepts an infrared command input and encodes a sig- 
nal for a conventional infrared emitter 228 to allow the 
interactive application 115 to control external devices. 

IS 

INfTFRACTIVg A PPLICATION EXECUTION 

[0037] Fig. 3 is a flowchart illustrating steps for receiv- 
ing and executing an interactive application using the 
compact information protocol according to a preferred 20 
embodiment of the present invention. The BR 120 
receives and decodes 31 0 an application header record 
prepared by the broadcast server 110, inserted by the 
DIU 116. and transmitted by the transmitter 118. The 
application header record describes the information that 2S 
follows and contains the interactive application identifi- 
cation code. 

[0038] The reminder functionality of the interactive 
application is desaibed by definitions, scripts, and com- 
mands which may be encoded and broadcast in any ao 
order. The definitions, scripts, and commands are 
received and decoded 312 by tiie BR 120 and define 
the reminder and response parameters used when exe- 
cuting 314 the reminder interactive application. 
[0039] Some or all of the received reminder interactive 35 
application maybe stored 312 witiiin the BR 120. In one 
embodiment, the interactive application is repeatedly 
broadcast allowing a BR 120 to tune to a program at 
any time yet receive the entire interactive application. 
Any desired updates to the stored interactive application 40 
may be received and decoded 316. If there are addi- 
tional or updated definitions, scripts, or commands, they 
may be sent until the application is complete 318. In one 
embodiment, a termination command may be broadcast 
to stop 320 the interactive application from reminder. 45 
[0040] A new interactive application may be sent at 
any time, including while an original application is set- 
ting a reminder or transmitting a response. For example, 
a new interactive application corresponding to a com- 
mercial may interrupt an original application corre- so 
sponding to a news program, the latter application can 
resume operation upon termination of the former. As 
part of this functionality, in one embodiment a suspend 
application command is sent by the new application in 
order to suspend operation of the original application, ss 
and a resume application command may be sent by 
either application to terminate the new application and 
resume operation of the original application. 



OPERATION OF REMINDER INTERACTIVE APPU- 
CATIQNS 

[0041] A preferred embodiment of the present inven- 
tion includes a reminder interactive application for exe- 
cution in the BR 120 that establishes and sets 
reminders for broadcast and non-broadcast events. 
[0042] Referring now to Fig. 4. there is shown a state 
diagram for operating a broadcast receiver 120 in 
accordance with tiie present invention to use reminder 
interactive applications. This behavior is implemented 
by the execution engine 217 executed by the processor 
210. The broadcast receiver 120 ts assumed to be 
tuned to some channel upon which broadcast data is 
being broadcast The execution engine 217 continually 
scans 400 broadcast data received fforh the transmitter 
118, and extracts any reminder interactive application 
115 that is included in the broadcast data. TTiese steps 
are in accordance with steps 310-312 of Rg. 3. The 
reminder interactive application 115 is stored in the first 
storage device 21 2 to allow the execution engine 217 to 
execute it upon conrvnand from the us^. The broadcast 
receiver 120 displays the broadcast program on a dis- 
play device 218, such as a television screen, for viewing 
in a normal nunner. 

[P043] Where a reminder interactive application 1 1 5 is 
present, the broadcast program will generally have con- 
tent that informs the user about some event related to 
the broadcast program. For exarrple, the broadcast pro- 
gram may be a commercial advertisement for a future 
broadcast event on tiie same or other channel, such as 
a pay-per-view program. Or the broadcast program may 
be a commercial advertisement for a non-broadcast 
event, such as a sale at a local retail store, a promotion 
for a concert, an auction, or any other type of event ttiat 
occurs independently of the broadcaster broadcasting 
data about such event. 

[0044] While the viewer is watching the broadcast pro- 
gram, she may decide to set a reminder to remind her 
afc»ut tiie event. To do so she activates 401 a button on 
an input device, such as a remote control unit, which 
sends a signal to tiie broadcast receiver 120. The 
broadcast receiver 120 receives this user input signal 
via the user input receiver 224 and executes 402 the 
reminder interactive application 115 stored in storage 
device 212. In another embodiment, a flashing icon is 
inKially presented on tiie display 218 to inform tiie 
viewer of the presence of an interactive application 115; 
tiie viewer can tiien activate the interactive application 
115 as desired. 

[0045] The reminder interactive application 115 uses 
its internally defined event description data to create a 
reminder confirmation form, which it displays to have 
tiie viewer confirm that she wants to set a reminder for 
the event The display is generated with the graphics 
overlay generator 216. and output on the display de/ice 
218. 

[0046]. Rg. 5 illusb-ates a simple reminder confirma- 
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tion fcMTTi 500. In this example, the event description 502 
included in the reminder interactive application 115 
includes the event name 'Its A Wonderful Life," a 
date/time of 8:00 pm on 3/3/98. and a channel The user 
responds to the form 500 by selecting the appropriate 
key on tfie user input device. e.g. a "Yes" or "Enter" key 
to activate a conesponding "^es" form button 504. or 
"No* oc "Cancel" key to activate the "No" form button 
504. 

[0047] The broadcast receiver 120 receives the user 
input. If the user input cancels 405 the reminder, then 
reminder interactive appiicalion 115 is exited, and no 
further action is taken. The broadcast receiver 120 
returns to scanning for the next interactive application 
that is broadcast 

[0048] If tiie user input confinns 403 the reminder, 
then the broadcast receiver 120 stores 404 reminder 
data from the reminder interactive application 115 in 
memory 213, and establishes a timer based on tiie 
reminder data. Generally the reminder data includes 
data for determining a futijre time for displaying a 
reininder for tine event, and an event description, tor 
example as shown in Fig. 5. The data for determining a 
future time may be the actual time that the reminder is 
desired, or an amount of time until the future time, or 
other variation. In any event, the broadcast receiver 1 20 
establishes a timer that eiqsires at the future time. The 
future time need not be tiie actual time at which tiie 
event occurs, but is preferably some time before tiie 
time of the event to allow the viewer to take whatever 
actions are desired for viewing or participating in the 
event. For example, fa a broadcast event such as tele- 
vision program about to be aired, the future time way be 
1-5 minutes before the event time. For a non-broadcast 
event, such as a sale at retail establishment, the future 
time may be several hours, or days before the time of 
the non-broadcast event. 

[0049] The present invention also allows for multiple 
reminders for a given event to be provided to tiie viewer. 
This allows tiie broadcast receiver 120 to notify tiie 
viewer several times before ttie event occurs. For exam- 
ple, for a broadcast event, reminders 1 day. 1 hour, and 
1 minute before the broadcast event may be defined in 
the reminder data, and displayed at the appropriate 
dates and times. Similariy for a non-broadcast event 
reminders 3, 2. and 1 day before the event may be 
defined in the reminder data. 
[0050] The timer may be an internal function of tiie 
execution engine 217, or it may be part of an underlying 
operating system that comrots tiie broadcast receiver 
120. In either case, the execution engine 217 maintains 
data which associates each timer with specific reminder 
data, thereby allowing tiie execution engine 217 to man- 
age multiple timers for multiple r^aminders at once, in the 
first implementation, ttie execution engine 217 is 
responsible for managing the timer, and does so by hav- 
ing the timer execute in tiie background while otiier 
functions are being handled, exh as executing other 



interactive applications, displaying program data, 
receiving user inputs, and so forth. In the tatter impte- 
merrtation, ttie operating system manages the timer, 
and notifies tiie execution engine 217 when the timer 

5 expires. Eitiier of tiiese or similar inrplementations may 
be used, as the specifics of how tiie timer is imple- 
mented is not material to the invention. 
[0051] After a timer is established 404, it atns until it 
expires 411. When a timer expires 411 the execution 

10 engine 21 7 obtains from memory 21 3 the event descrip- 
tion associated with the timer in order to create 406 a 
reminder display form which is used as the reminder to 
tiie viewer. This form may be an internally stored 
reminder display interactive application tiiat displays the 

IS event description, or it may be constructed from graphic 
primitives available to the execution engine 217 and 
internal engine functions. It should be noted ttiat in rrxjst 
cases tiie reminder interactive application 115 which 
was initially used to establish the reminder is no longer 

20 present, and not available for execution, and it is for tills 
reason tiiat either the execution engine 217 itself or a 
resident reminder display interactive application is used 
to display the reminder display form. 
[0052] The reminder display fomri with event descrip- 

25 tion is displayed to the viewer, either for a predeter- 
mined amount of time (413). or preferably until tiie 
viewer confirms 417 tiie display or cancels 415. The 
broadcast receiver 120 receives the viewer's input if 
any, and proceeds accordingly. 

30 [0053] Fig. 6 illustrates an exemplary reminder display 
fomi 600 for a broadcast event, here a pay per view 
event which requires viewer acknowledgment 604. The 
viewer may either confirm ("Yes") or cancel ("No") tiie 
reminder. In tiiis example, if the viewer confirms 417 tiie 

35 reminder, then the broadcast receiver 1 20 automatically 
tunes 410 to tiie channel associated with the broadcast 
event, using the information in the event description. 
Further, since this is a pay-per-view event the execution 
engine 217 automatically initiates the necessary func- 

40 tions to purchase tiie pay-per-vtew event, such as stor- 
ing the necessary viewer billing information in memory 
21 3 tor uploading to the broadcast system for billing pur- 
poses. Mechanisms for purchasing pay-per-view events 
are well known to tix>se of skill in the art. For broadcast 

45 events that do not require a purchase, the execution 
engine 217 need only tune to tiie channel defined tor 
the broadcast event If the viewer cancels 415 the 
reminder (i.e. "No"), ttien the execution engine 217 
takes no further action, and does not tune to the chan- 

so nel tor tiie broadcast event. 

[0054] Reminders for non-broadcast events are simi- 
lar to reminders for broadcast events. Fig. 7 illustrates 
an exemplary reminder confirmation form 700 for a non- 
broadcast event, in this example a sale at a local retail 

55 store. This form 700 would be displayed 406 concur- 
rentiy witii the display of a commercial advertisement. 
Here, the event desaiption 702 stored in memory 213 
would include the event name "Macy's After-Thanksgiv- 
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ing Sale" and dateAime data for the start of the event 
For multiple reminders, the reminder data may include 
data to set future times for reminders 3, 2. and 1 day in 
advance of the o^ent or other desirable schedule. 
Again, the user can either confirm or cancel the 5 
reminder. A reminder display form for a non-broadcast 
event would be similar to the form shewn in Fig. 6, txjt 
with the appropriate content. A reminder display form for 
a non-broadcast event is displayed to the viewer, either 
fa a predetermined amount of time (413), or preferably 10 
until the viewer conf imns 41 7 the display or cancels 415. 
If a timeout 413 occurs, then the BR 120 returns to 
scanning 400 for the next interactive application. 
[0055] In an embodiment with multiple reminders for a 
given event, a series of reminders includes a number of is 
non-terminal reminders followed by a last terminal 
reminder. In this embodiment after each non-temiinal 
reminder is displayed 406 to the viewer and confirmed 
418. the execution engine 217 resets 408 a timer for the 
future time tor displaying the next reminder. In this fash- 20 
ion, the series of reminders are appropriately displayed 
to the viewer. Each of these reminders may have its own 
event desaiption to provide a logical handling of viewer 
inputs. For example, non-terminal reminders may allow 
the viewer to confirm the next reminder or cancel the 2S 
series of remirkders. In the latter case, the execution 
engine 21 7 removes the reminder data for this reminder 
from memory 213. If the viewer does not cancel or con- 
firm the reminder before a timeout 421, then the timer 
for the next reminder is automatically set 408. 30 
[0056] In sunurary, the present invention provides a 
system, method, and various software based products 
to allow an interactive broadcast system to be used for 
establishing reminders for both broadcast and non- 
broadcast events. Because the reminders are estab- 35 
lished concurrently while viewing a broadcast program 
related to the desired future event or reminder, the 
viewer does not have to access and traverse a separate 
program guide to estat)lish a reminder. In addition, this 
allows the viewer to set ren^nders for non-broadcast 40 
events which do not appear in conventional program 
guides. 

Claims 

45 

1. A computer implemented method of operating a 
broadcast receiver for establishing reminders for 
events related to broadcast programs, the broad- 
cast receiver including a local memay, the method 
comprising: so 

receiving broadcast data including at least one 
broadcast program and separate reminder 
data associated with the broadcast program; 
displaying the broadcast program; ss 
concurrently with displaying the broadcast pro- 
gram, receiving a user input to establish a 
reminder for an event related to t^3 broadcast 



pro^m; 

storing in the local memory the reminder data 
for the event, including data tor determining a 
future time to display the reminder, and a 
description of the event; and 
responsive to the future time, displaying on a 
display device coupled to the broadcast 
receiver the reminder induding the description 
of the event 

2. The method of claim 1, wherein an event is a non- 
broadcast event, arxl the broadcast program is an 
advertisement or advance notice for the non-broad- 
cast event 

3. The method of daim 1 or 2, wherein the broadcast 
receiver tunes broadcast programs on a plurality of 
channels, the method further comprising: 

receiving a broadcast program on a first chan- 
nel indicating a broadcast event occuning at a 
future time on a second channel; and 
receiving a user input to establish a reminder 
for an event related to the broadcast program, 
corrprising receiving while tuning on the first 
channel a user input to establish a reminder for 
the broadcast event occunring at the future time 
on the secoTKl channel. 

4. The method of one of the preceding claims, further 
comprising: 

establishing in the broadcast receiver a timer 
that expires at the future time to display the 
reminder. 

5. The method of one of the preceding claims, further 
comprising: 

tuning to first channel, and displaying a first 
broadcast program on the first channel; 
displaying a reminder for a second broadcast 
program occurring on a second channel differ- 
ent from the first channel; and 
tuning to the second channel, and displaying 
the second broadcast program. 

6. The method of daim 5. further comprising: 

storing data indicative of a purchase of the sec* 
ond broadcast program. 

7. A computer implemented method of operating a 
broadcast receiver for establishing reminders for 
events related to broadcast programs, the broad- 
cast receiver including a local memory, the method 
comprising: 
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receiving broadcast data including at least one 
broadcast pro^m and a reminder Interactive 
application associated with the broadcast pro- 
gram; 

displaying the broadcast pro^^; s 
concuaently with displaying the broadcast pro- 
gram, receiving a user input activating the 
reminder interactive application to establish a 
reminder for an event related to the broadcast 
program; 

storing in a local men(x>ry reminder data for the 
event, the reminder data including data for 
determining a future time to display the 
reminder arKl a description of the event; 
maintaining a timer that expires at the future is 
time; and 

responsive to the timer expiring, displaying the 
reminder including the description of the event 

8. The method of claim 7. further conprising: so 

storing a reminder form in the local memory; 
and 

displaying the rernnder including the descrip- 
tion of the event further comprises: ss 

combining the reminder form and the 
description of the event to create the 
reminder. 

30 

9. An apparatus for establishing and communicating 
reminders of events related to broadcast programs, 
the apparatus comprising: 

a tuner for receiving broadcast data including 35 
at least one broadcast program and reminder 
data for an event associated with the broadcast 
program, the reminder data including data for 
determining a future time to display a reminder 
of the event, and a description of the event; 4o 
a memory coupled to the tuner to receive and 
store the rentinder data in response to a user 
input requesting establishment of the reminder 
for the event: 

a timer coupled to the memory, the timer expir- 4s 
ing at the future time; and 
a processor coupled to the memory and the 
timer to receive the event descriptfon and a sig- 
nal from the timer indicating that the time has 
expired, and to generate the reminder from the so 
reminder data, the reminder including the event 
description, the processa outputdng the 
reminder for display on a display device. 

10. The system of claim 9, wherein: ss 

the broadcast data includes an executable 
reminder interactive application that contains 



the reminder data; 

the processor executes the reminder interac- 
tive application to receive the user input 
requesting establishmertt of the reminder for 
the event stores the reminder data contained 
in the reminder interactive application in the 
memory, and establishes and manages the 
timer to expire at the future time. 
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